package com.bzkj.system.service;

import com.bzkj.system.domain.SysBasicDataLog;

import java.util.List;
import java.util.Map;

/**
 * 基础数据操作日志 服务层
 *
 * @author ruoyi
 */
public interface ISysBasicDataLogService {

    /**
     * 新增操作日志
     *
     * @param basicDataLog 操作日志对象
     * @return 结果
     */
    public Long insertOperlog(SysBasicDataLog basicDataLog);

    /**
     * 查询系统操作日志集合
     *
     * @param operLog 操作日志对象
     * @return 操作日志集合
     */
    public List<SysBasicDataLog> selectOperLogList(SysBasicDataLog operLog);

    /**
     * 查询系统操作日志集合（导出）
     *
     * @param operLog 操作日志对象
     * @return 操作日志集合
     */
    public List<SysBasicDataLog> selectOperLogListExport(SysBasicDataLog operLog);

    /**
     * 批量删除系统操作日志
     *
     * @param operIds 需要删除的操作日志ID
     * @return 结果
     */
    public int deleteOperLogByIds(Long[] operIds);

    /**
     * 查询操作日志详细
     *
     * @param operId 操作ID
     * @return 操作日志对象
     */
    public SysBasicDataLog selectOperLogById(Long operId);

    /**
     * 清空操作日志
     */
    public void cleanOperLog();

    /**
     * 获取字段翻译
     *
     * @param tableName 表名
     * @return 字段翻译
     */
    List<Map<String, String>> getFieldTranslations(String tableName);

    //------------------------------------------------仓库管理相关------------------------------------------------

    /**
     * 根据主键查询主表信息
     *
     * @param pkField   主键字段
     * @param tableName 表名
     * @param pkValue   主键值
     * @return
     */
    Map<String, Object> selectWarehouseByPk(String pkField, String tableName, Object pkValue);
    Map<String, Object> selectWarehouseByMultiPk(String[] pkField, String tableName, Object[] pkValue);

    /**
     * 根据主键查询关联表信息
     *
     * @param pkField   关联字段
     * @param tableName 表名
     * @param pkValue   关联字段值
     * @return 单据表头信息
     */
    List<Map<String, Object>> selectRelatedByPk(String pkField, String tableName, Object pkValue);
}
